<template>
  <div>
    <div>
      <el-input v-model="jl.name"
                placeholder="添加职称等级" size="small"
                prefix-icon="el-icon-plus" style="width: 300px;margin-right: 6px"></el-input>
      <el-select size="small" v-model="jl.titleLevel" placeholder="职称选择">
        <el-option
            v-for="item in titleLevels"
            :key="item"
            :label="item"
            :value="item">
        </el-option>
      </el-select>
      <el-button size="small" style="margin-left: 5px"
                 type="primary" icon="el-icon-plus"
                 @click="addJl">添加</el-button>
    </div>
    <div style="margin-top: 10px">
      <el-table
          :data="jls"
          border
          stripe
          style="width: 70%"
          @selection-change="handleSelectionChange">
        <el-table-column
            type="selection"
            width="55">
        </el-table-column>
        <el-table-column
            prop="id"
            label="编号"
            width="55">
        </el-table-column>
        <el-table-column
            prop="name"
            label="职称名称"
            width="150">
        </el-table-column>
        <el-table-column
            prop="titleLevel"
            label="职称等级"
            width="120">
        </el-table-column>
        <el-table-column
            prop="createDate"
            label="创建时间"
            width="150">
        </el-table-column>
        <el-table-column
            prop="enabled"
            label="是否启用"
            width="150">
          <template slot-scope="scope">
            <el-tag v-if="scope.row.enabled" type="success">已启用</el-tag>
            <el-tag v-else type="danger">未启用</el-tag>
          </template>
        </el-table-column>
        <el-table-column
            label="操作">
          <template slot-scope="scope">
            <el-button size="small" @click="showEditView(scope.row)">编辑</el-button>
            <el-button size="small" type="danger" @click="deleteHandler(scope.row)">删除</el-button>

          </template>
        </el-table-column>
      </el-table>
      <el-button size="small" type="danger"
                 @click="deleteMany"
                 :disabled="this.multipleSelection==0"
                 style="margin-top: 10px">批量删除</el-button>
    </div>
    <el-dialog
        title="编辑职称"
        :visible.sync="dialogVisible"
        width="30%">
      <table>
        <tr>
          <td>
            <el-tag>职称名称</el-tag>
          </td>
          <td>
            <el-input size="small" v-model="updateJl.name"></el-input>
          </td>
        </tr>
        <tr>
          <td><el-tag>职称等级</el-tag></td>
          <td>
            <el-select size="small" v-model="updateJl.titleLevel" placeholder="职称选择">
              <el-option
                  v-for="item in titleLevels"
                  :key="item"
                  :label="item"
                  :value="item">
              </el-option>
            </el-select>
          </td>
        </tr>
        <tr>
          <td><el-tag>是否启用</el-tag></td>
          <td>
            <el-switch
                v-model="updateJl.enabled"
                active-color="#13ce66"
                inactive-color="#ff4949"
                active-text="已启用"
                inactive-text="未启用">
            </el-switch>
          </td>
        </tr>
      </table>
      <span slot="footer" class="dialog-footer">
    <el-button @click="dialogVisible = false">取 消</el-button>
    <el-button type="primary" @click="doUpdate">确 定</el-button>
  </span>
    </el-dialog>
  </div>
</template>

<script>
export default {
name: "JobLevelMana",
  mounted() {
    this.initJls()
  },
  methods:{
    deleteMany(){
      this.$confirm('此操作将永久删除['+this.multipleSelection.length+']条职称, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        let ids='?'
        this.multipleSelection.forEach(item=>{
          ids+='ids='+item.id+'&'
        });
        this.deleteRequest('/system/basic/joblevel/'+ids).then(resp=>{
          if (resp){
            this.initJls()
          }
        })
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });
    },
    handleSelectionChange(val){
      this.multipleSelection=val

    },
    doUpdate(){
      this.putRequest('/system/basic/joblevel/',this.updateJl).then(resp=>{
        if (resp){
          this.initJls()
          this.dialogVisible=false
        }
      })

    },
  //编辑
    showEditView(data){
      Object.assign(this.updateJl,data)
      //将时间默认为空
      this.updateJl.createDate=''
      this.dialogVisible=true
    },
  //删除
    deleteHandler(data){
      this.$confirm('此操作将永久删除['+data.name+']职称, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.deleteRequest('/system/basic/joblevel/'+data.id).then(resp=>{
          if (resp){
            this.initJls()
          }
        })
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });

    },
    initJls(){
      this.gettRequest('/system/basic/joblevel/').then(resp=>{
        if (resp){
          this.jls=resp
          this.jl.name=''
          this.jl.titleLevel=''
        }
      })
    },
    //添加职称
    addJl(){
      if (this.jl.name && this.jl.titleLevel){
        this.postRequest('/system/basic/joblevel/',this.jl).then(resp=>{
          if (resp){
            this.initJls()
          }
        })
      } else {
        this.$message.error('添加职称和等级不能为空')
      }
    },
  },
  data(){
    return{
      jl:{
        name:'',
        titleLevel:''
      },
      titleLevels:[
          '正高级',
          '副高级',
          '中级',
          '初级',
          '员级'
      ],
      jls:[],
      updateJl:{
        name:'',
        titleLevel: '',
        enabled:false,
      },
      dialogVisible:false,
      multipleSelection:[],
    }
  }
}
</script>

<style scoped>

</style>